package com.ywgt;

public class KMPSearch {
    public static void main(String[] args) {
        String str1="ABCDA ASDABCDEAS ASDCEWQAABCD";
        String str2="ABCDEA";
        int index = getIndex(str1, str2,getEMP(str2));
        System.out.println(index);
    }

    public static int getIndex(String str1,String str2,int [] next){
        for (int i = 0,j=0; i <str1.length() ; i++) {
            while (j>0&&str1.charAt(i)!=str2.charAt(j)){
                j=next[j-1];
            }
            if(str1.charAt(i)==str2.charAt(j)){
                j++;
            }
            if(j==str2.length()){
                return i-j+1;
            }
        }
        return -1;
    }

    /**
     * 获取EMP表
     * @param str
     * @return
     */
    public static int[] getEMP(String str){
        int [] next=new int[str.length()];
        next[0]=0;
        for (int i = 1,j=0; i <str.length() ; i++) {
            while(j>0&&str.charAt(i)!=str.charAt(j)){
                j=next[j-1];
            }
            if(str.charAt(i)==str.charAt(j)){
                j++;

            }
            next[i]=j;
        }
        return next;
    }
}
